//
//  HMBasicTableViewController.swift
//  01-SinaWeibo
//
//  Created by 周英培 on 16/5/21.
//  Copyright © 2016年 周英培. All rights reserved.
//

import UIKit

//5.遵守协议
class HMBasicTableViewController: UITableViewController,HMVisitorLoginViewDelegate {

    //把共同的东西抽取成一个基类，让其他的控制器去继承就行
//    var userLogin = false
    var userLogin = HMUserInfoViewModel.sharedUserInfoViewModel.loadUserInfo() != nil
    
    
    //设置访客视图的属性，这样在子控制器都可以调用这个属性
    lazy var visitorLoginView : HMVisitorLoginView = HMVisitorLoginView()
    
    override func loadView() {
        
        if userLogin {//如果登录，显示tableView
            
            super.loadView()
            
        } else {//如果未登录，显示未登录界面
            
            loadVisitorLoginView()
            
        }
        
    }
    
    override func viewDidLoad() {
        super.viewDidLoad()

        
    }
    
    
    func loadVisitorLoginView() {
        
//        let v = HMVisitorLoginView()
        
        //        v.backgroundColor = UIColor.greenColor()
        
        view = visitorLoginView
        
        //6.指定代理
        visitorLoginView.visitorDelegate = self
    }

    //7.实现协议方法
    
    func userWillLogin() {
    
        print("登录")
        let auth = HMOAuthViewController()
        
        //内嵌个导航控制器 声称导航条
        let nav = UINavigationController(rootViewController:auth)
        
        
        presentViewController(nav, animated: true, completion: nil)
        
    
    }
    
    func userRegister() {
        print("注册")
    }
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

    // MARK: - Table view data source

//    override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
//        // #warning Incomplete implementation, return the number of sections
//        return 0
//    }
//
//    override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
//        // #warning Incomplete implementation, return the number of rows
//        return 0
//    }

    /*
    override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCellWithIdentifier("reuseIdentifier", forIndexPath: indexPath)

        // Configure the cell...

        return cell
    }
    */

    /*
    // Override to support conditional editing of the table view.
    override func tableView(tableView: UITableView, canEditRowAtIndexPath indexPath: NSIndexPath) -> Bool {
        // Return false if you do not want the specified item to be editable.
        return true
    }
    */

    /*
    // Override to support editing the table view.
    override func tableView(tableView: UITableView, commitEditingStyle editingStyle: UITableViewCellEditingStyle, forRowAtIndexPath indexPath: NSIndexPath) {
        if editingStyle == .Delete {
            // Delete the row from the data source
            tableView.deleteRowsAtIndexPaths([indexPath], withRowAnimation: .Fade)
        } else if editingStyle == .Insert {
            // Create a new instance of the appropriate class, insert it into the array, and add a new row to the table view
        }    
    }
    */

    /*
    // Override to support rearranging the table view.
    override func tableView(tableView: UITableView, moveRowAtIndexPath fromIndexPath: NSIndexPath, toIndexPath: NSIndexPath) {

    }
    */

    /*
    // Override to support conditional rearranging of the table view.
    override func tableView(tableView: UITableView, canMoveRowAtIndexPath indexPath: NSIndexPath) -> Bool {
        // Return false if you do not want the item to be re-orderable.
        return true
    }
    */

    /*
    // MARK: - Navigation

    // In a storyboard-based application, you will often want to do a little preparation before navigation
    override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
        // Get the new view controller using segue.destinationViewController.
        // Pass the selected object to the new view controller.
    }
    */

}
